package com.belf.console.service;

import com.belf.common.core.domain.AjaxResult;
import com.belf.common.core.domain.entity.SysUser;
import com.belf.console.domain.DataSourceInfo;

import java.util.List;

/**
 * 数据源信息Service接口
 * 
 * @author belf
 * @date 2024-06-20
 */
public interface IDataSourceInfoService 
{
    /**
     * 查询数据源信息
     * 
     * @param id 数据源信息主键
     * @return 数据源信息
     */
    public DataSourceInfo selectDataSourceInfoById(String id);

    /**
     * 查询数据源信息列表
     * 
     * @param dataSourceInfo 数据源信息
     * @return 数据源信息集合
     */
    public List<DataSourceInfo> selectDataSourceInfoList(DataSourceInfo dataSourceInfo);

    long selectDataCount(DataSourceInfo dataSourceInfo);

    /**
     * 新增数据源信息
     * 
     * @param dataSourceInfo 数据源信息
     * @return 结果
     */
    public int insertDataSourceInfo(DataSourceInfo dataSourceInfo);

    /**
     * 修改数据源信息
     * 
     * @param dataSourceInfo 数据源信息
     * @return 结果
     */
    public int updateDataSourceInfo(DataSourceInfo dataSourceInfo);

    /**
     * 批量删除数据源信息
     * 
     * @param ids 需要删除的数据源信息主键集合
     * @return 结果
     */
    public int deleteDataSourceInfoByIds(String[] ids);

    /**
     * 删除数据源信息信息
     * 
     * @param id 数据源信息主键
     * @return 结果
     */
    public int deleteDataSourceInfoById(String id);

    AjaxResult databaseCheck(DataSourceInfo dataSourceInfo);

    AjaxResult dataSourceGetDBS(DataSourceInfo dataSourceInfo);

    AjaxResult dataSourceGetTables(DataSourceInfo dataSourceInfo);
    AjaxResult dataSourceGetObjects(DataSourceInfo dataSourceInfo);


    List<DataSourceInfo> selectDataSourceInfoByIds(String[] ids);

    AjaxResult selectDataSourceInfoCount(SysUser user);
    void setDataSourceDatabase(DataSourceInfo dataSourceInfo,String databaseName);

    AjaxResult dataSourceGetColumns(DataSourceInfo dataSourceInfo);

    AjaxResult dataSourceGetDbColumns(DataSourceInfo dataSourceInfo);

    AjaxResult listDatabaseAndSchema(DataSourceInfo dataSourceInfo);

    AjaxResult listConfigDbTypes(DataSourceInfo dataSourceInfo);
}
